Servlet এর মধ্যে Authentication এবং Authorization

Java Technologies - সার্ভলেটস (Servlets) - Servlet Security Management
261

Authentication এবং Authorization হল ওয়েব অ্যাপ্লিকেশন সিকিউরিটি নিশ্চিত করার জন্য অত্যন্ত গুরুত্বপূর্ণ কৌশল। Authentication হচ্ছে একটি প্রক্রিয়া যার মাধ্যমে নিশ্চিত করা হয় যে, ব্যবহারকারী কে এবং সে সঠিক তথ্য প্রদান করছে কি না, আর Authorization হচ্ছে প্রক্রিয়া যার মাধ্যমে এটি নিশ্চিত করা হয় যে, অনুমোদিত ব্যবহারকারী নির্দিষ্ট রিসোর্স বা কার্যক্রমে অ্যাক্সেস পাবে কি না।

Servlets ব্যবহার করে ওয়েব অ্যাপ্লিকেশনে Authentication এবং Authorization পরিচালনা করা যেতে পারে। এই দুইটি প্রক্রিয়াকে কার্যকর করার জন্য সার্ভলেটের মাধ্যমে ব্যবহারকারীদের লগইন সিস্টেম এবং অ্যাক্সেস কন্ট্রোল সেটআপ করা হয়।

১. Authentication in Servlets

Authentication হল একটি প্রক্রিয়া যেখানে সিস্টেম যাচাই করে যে ব্যবহারকারী সঠিকভাবে সাইন ইন করেছে কি না, অর্থাৎ সে আসলেই দাবী করা ব্যক্তি কি না। সাধারণভাবে username এবং password ব্যবহার করে ব্যবহারকারীকে যাচাই করা হয়।

উদাহরণ: Basic Authentication in Servlet

এখানে একটি সাধারণ username এবং password যাচাই করার উদাহরণ দেওয়া হলো, যেখানে ব্যবহারকারীর ইনপুট যাচাই করা হয় এবং লগইন সফল হলে তাকে অন্য পৃষ্ঠায় রিডাইরেক্ট করা হয়।

HTML Login Form:
<!DOCTYPE html>
<html>
<head><title>Login</title></head>
<body>
    <h2>Login</h2>
    <form action="login" method="post">
        <label for="username">Username:</label>
        <input type="text" id="username" name="username" required /><br/>
        <label for="password">Password:</label>
        <input type="password" id="password" name="password" required /><br/>
        <input type="submit" value="Login" />
    </form>
</body>
</html>
Login Servlet:
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;

public class LoginServlet extends HttpServlet {

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String username = request.getParameter("username");
        String password = request.getParameter("password");

        // Hard-coded credentials for demonstration purposes
        String validUsername = "user";
        String validPassword = "password123";

        // Authentication logic
        if (username != null && username.equals(validUsername) && password != null && password.equals(validPassword)) {
            // Successful login
            response.sendRedirect("welcome.jsp");
        } else {
            // Authentication failed
            response.getWriter().println("Invalid username or password");
        }
    }
}

এখানে:

  • ব্যবহারকারী username এবং password ফর্মে প্রদান করে।
  • সার্ভলেট doPost() মেথডে ইউজারের ইনপুট যাচাই করে, যদি সঠিক হয়, তবে তাকে welcome.jsp পেজে রিডাইরেক্ট করা হয়।
  • ভুল ইনপুট দিলে একটি ত্রুটি বার্তা দেখানো হয়।

২. Authorization in Servlets

Authorization হল প্রক্রিয়া যার মাধ্যমে এটি নিশ্চিত করা হয় যে, authenticated (যাচাইকৃত) ব্যবহারকারী কোনো নির্দিষ্ট রিসোর্সে অ্যাক্সেস করতে পারে কি না। উদাহরণস্বরূপ, আপনি শুধুমাত্র admin ব্যবহারকারীকে একটি অ্যাডমিন প্যানেল অ্যাক্সেস দিতে চান।

উদাহরণ: Authorization Using Role-Based Access Control

এখানে একটি role-based access control (RBAC) সিস্টেমের মাধ্যমে admin রোল ভিত্তিক অ্যাক্সেস কন্ট্রোল উদাহরণ দেওয়া হলো।

HTML Form for Login with Role:
<!DOCTYPE html>
<html>
<head><title>Login</title></head>
<body>
    <h2>Login</h2>
    <form action="login" method="post">
        <label for="username">Username:</label>
        <input type="text" id="username" name="username" required /><br/>
        <label for="password">Password:</label>
        <input type="password" id="password" name="password" required /><br/>
        <input type="submit" value="Login" />
    </form>
</body>
</html>
Login Servlet with Role-Based Authorization:
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;

public class LoginServlet extends HttpServlet {

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String username = request.getParameter("username");
        String password = request.getParameter("password");

        // Hard-coded credentials for demonstration purposes
        String validUsername = "admin";
        String validPassword = "adminpass";
        String userRole = "admin";  // User's role (in a real scenario, roles would come from a database)

        // Authentication logic
        if (username != null && username.equals(validUsername) && password != null && password.equals(validPassword)) {
            // Authorization logic: Check user's role
            if (userRole.equals("admin")) {
                // Authorized to access admin panel
                response.sendRedirect("adminPanel.jsp");
            } else {
                // Unauthorized access
                response.getWriter().println("You do not have permission to access this page.");
            }
        } else {
            // Authentication failed
            response.getWriter().println("Invalid username or password");
        }
    }
}

এখানে:

  • ব্যবহারকারী username এবং password প্রদান করে।
  • সার্ভলেট ইউজারের role চেক করে, যদি ইউজারের role "admin" হয়, তাকে adminPanel.jsp পেজে রিডাইরেক্ট করা হয়।
  • যদি ইউজারের রোল "admin" না হয়, তাকে অ্যাক্সেস প্রদান করা হয় না।

৩. Authentication and Authorization with web.xml Configuration

ওয়েব অ্যাপ্লিকেশনে সাধারণভাবে web.xml কনফিগারেশন ফাইল ব্যবহার করে Authentication এবং Authorization কনফিগার করা হয়।

উদাহরণ: Basic Authentication using web.xml

<web-app>
    <!-- Configure security constraints for roles -->
    <security-constraint>
        <web-resource-collection>
            <web-resource-name>Admin Pages</web-resource-name>
            <url-pattern>/admin/*</url-pattern>
        </web-resource-collection>
        <auth-constraint>
            <role-name>admin</role-name>
        </auth-constraint>
    </security-constraint>

    <!-- Define login configuration -->
    <login-config>
        <auth-method>BASIC</auth-method>
        <realm-name>ExampleRealm</realm-name>
    </login-config>

    <!-- Define security roles -->
    <security-role>
        <role-name>admin</role-name>
    </security-role>

</web-app>

এখানে:

  • <security-constraint> এবং <auth-constraint> দ্বারা admin রোলের জন্য অ্যাক্সেস কন্ট্রোল সেট করা হয়েছে।
  • <login-config> দ্বারা BASIC অথেনটিকেশন কনফিগার করা হয়েছে, যেখানে ইউজারনেম এবং পাসওয়ার্ড ব্যবহার করে অথেনটিকেশন করা হয়।

৪. Error Handling for Authentication and Authorization

প্রতিটি অথেনটিকেশন এবং অথোরাইজেশন প্রক্রিয়ায় ত্রুটি হ্যান্ডলিং গুরুত্বপূর্ণ। যদি ব্যবহারকারী সঠিকভাবে অথেনটিকেট না হয় অথবা অ্যাক্সেসের অনুমতি না পায়, তখন তাকে একটি ত্রুটি পেজে রিডাইরেক্ট করা উচিত।

উদাহরণ: Error Handling for Authentication Failure

// Inside LoginServlet
if (username == null || password == null || !username.equals(validUsername) || !password.equals(validPassword)) {
    response.sendError(HttpServletResponse.SC_UNAUTHORIZED, "Authentication Failed");
}

এখানে, যদি ইউজারনেম বা পাসওয়ার্ড ভুল হয়, তবে SC_UNAUTHORIZED (401) স্ট্যাটাস কোড সহ ত্রুটি মেসেজ প্রদান করা হবে।

সারাংশ

Authentication এবং Authorization সার্ভলেট ব্যবহার করে ওয়েব অ্যাপ্লিকেশন সিকিউরিটি নিশ্চিত করার জন্য দুটি গুরুত্বপূর্ণ প্রক্রিয়া। Authentication ইউজারকে যাচাই করে এবং Authorization ইউজারের অ্যাক্সেস অনুমোদন বা প্রত্যাখ্যান করে। সার্ভলেটের মাধ্যমে সহজেই লগইন, রোল-বেসড অ্যাক্সেস কন্ট্রোল, এবং ত্রুটি হ্যান্ডলিং সেটআপ করা সম্ভব, যা অ্যাপ্লিকেশনের সিকিউরিটি উন্নত করে।

web.xml ফাইলও ব্যবহারকারীদের অথেনটিকেশন এবং অথোরাইজেশন কনফিগারেশন সহজভাবে নির্ধারণ করতে সহায়তা করে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...